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COUNTER-BASED CLOCK DOUBLER CIRCUITS AND METHODS WITH 
OPTIONAL DUTY CYCLE CORRECTION AND OFFSET 

FIELD OF THE INVENTION 

[0001] The invention relates to clock doubler circuits. 
More particularly, the invention relates to counter-based 
clock doubler circuits and methods optionally having duty 
cycle correction and offset capabilities. 

BACKGROUND OF THE INVENTION 

[0002] Clock signals are used in virtually every IC and 
electronic system to control timing. For example, every time 
a rising edge occurs on a clock signal, all the flip-flops in 
a circuit might change state. Clearly, the higher the 
frequency of the clock signal, the faster the circuit 
operates. Therefore, where performance is an issue, circuit 
designers usually prefer to use the fastest available clock 
that can be supported by the delays on the logic paths 
through the circuit. In other words, the performance of a 
circuit is typically limited by the logic delays on the 
slowest logic path. However, sometimes the longest path 
delay through the circuit is significantly shorter than the 
period of the available clock, and the frequency of the 
available clock becomes the limiting factor. 
[0003] To overcome this limitation, circuit designers can 
double the frequency of a clock signal using a phase-lock 
loop (PLL) or delay-lock loop (DLL) circuit. However, PLLs 
are analog in nature and take a long time to simulate, and a 
design that works in one manufacturing process may stop 
working when manufactured using another process. Therefore, 
PLLs are very difficult to design, and often are not feasible 
in a given circuit or system. DLLs can also be very 
complicated and difficult to design. Additionally, DLLs 
typically consume a great deal of silicon area. Therefore, 
clock doubling is often not feasible using known circuits and 
methods . 
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[0004] Therefore, it is desirable to provide circuits and 
methods that enable a circuit designer to double the 
frequency of an input clock without using a PLL or DLL, using 
a fairly simple circuit that consumes a relatively small 
amount of silicon area. Preferably, such circuits and 
methods can optionally be implemented using the logic 
resources included in a programmable logic device (PLD) . 

SUMMARY OF THE INVENTION 

[0005] The invention provides clock doubler circuits and 
methods that use counters to define the desired positions of 
the output clock edges . A clock doubler circuit accepts an 
input clock signal and provides an output clock signal having 
a frequency twice that of the input clock signal. A clock 
doubler circuit according to an embodiment of the invention 
includes a plurality of counter circuits, each clocked by a 
count clock relatively much faster than the input clock 
signal. In some embodiments, each counter includes a small 
oscillator circuit implemented in the same fashion and 
generating a count clock for the counter. Thus, each counter 
uses a count clock having the same clock frequency. 
[0006] A first counter is periodically enabled to count 
for one input clock period, and the counted value is stored 
in a register. Thus, the stored value represents the number 
of counts in one input clock period. The stored value is 
then divided (e.g., by two), the divided value representing 
the number of counts in a given fraction (e.g., half) of the 
input clock period. The divided value is then provided to a 
second counter that counts (for example) from zero to the 
divided value. Thus, the second counter generates a pulse at 
a predetermined time in the input clock period (e.g., halfway 
through the input clock period) . Other counters running at 
the same clock rate can be used to generate pulses at other 
times in the input clock cycle, as desired. The pulses from 
the counters are used in combination with the input clock 
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coupled to the output terminal of the reset counter circuit, 
and an output terminal coupled to the output clock terminal. 
[0010] Other embodiments of the invention provide methods 
of providing an output clock signal having a frequency twice 
that of an input clock signal. According to one embodiment, 
a method of providing from an input clock signal an output 
clock signal having a frequency twice that of the input clock 
signal includes: counting a first number of counts between 
successive first edges of the input clock signal; dividing 
the first number to provide a divided number; counting a 
second number of counts following each first edge of the 
input clock signal and comparing the second number with the 
divided number; providing a first pulse on the output clock 
signal in response to each first edge of the input clock 
signal; and providing a second pulse on the output clock 
signal based on results of comparing the second number with 
the divided number. 

BRIEF DESCRIPTION OF THE DRAWINGS 

[0011] The present invention is illustrated by way of 
example, and not by way of limitation, in the following 
figures . 

[0012] Fig. 1 illustrates a first prior art clock doubler 
circuit without duty cycle correction (DCC) . 

[0013] Fig. 2 illustrates a second prior art clock doubler 
circuit without DCC. 

[0014] Fig. 3 illustrates a third prior art clock doubler 
circuit without DCC. 

[0015] Fig. 4 illustrates a prior art clock doubler 
circuit that uses a DLL and does not provide DCC. 
[0016] Fig. 5 illustrates a prior art clock doubler 
circuit that uses a DLL and provides DCC. 

[0017] Fig. 6 is a schematic diagram of a clock doubler 
circuit according to an embodiment of the invention that 
provides 50 percent DCC. 
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[0018] Fig. 7 is a timing diagram for the clock doubler of 
Fig. 6. 

[0019] Fig. 8 is a schematic diagram of a counter circuit 
that can optionally be used to implement three of the 
counters in the embodiment of Fig. 6. 

[0020] Fig. 9 is a schematic diagram of a clock doubler 
circuit according to an embodiment of the invention that 
provides 25 percent DCC. 

[0021] Fig. 10 is a timing diagram for the clock doubler 
circuit of Fig. 9. 

[0022] Fig. 11 is a schematic diagram of a clock doubler 
circuit according to an embodiment of the invention that 
provides 25 percent DCC and a predetermined offset. 
[0023] Fig. 12 is a timing diagram for the clock doubler 
circuit of Fig. 11. 

[0024] Fig. 13 is a schematic diagram of a divide-by-eight 
register that can optionally be used in the embodiment of 
Fig. 11. 

[0025] Fig. 14 is a schematic diagram of a divide-by- two 
register that can optionally be used in the embodiment of 
Fig. 11. 

[0026] Fig. 15 is a schematic diagram of a clock doubler 
circuit according to an embodiment of the invention that does 
not provide DCC, and which passes the input clock signal to 
the output clock terminal when a reset signal is active. 
[0027] Fig. 16 is a schematic diagram of a clock doubler 
circuit according to an embodiment of the invention that does 
not provide DCC, and which provides a low value to the output 
clock terminal when a reset signal is active. 
[0028] Fig. 17 is a schematic diagram of a clock doubler 
circuit according to an embodiment of the invention that 
optionally provides or does not provide DCC. 
[0029] Fig. 18 illustrates the steps of a novel method of 
providing from an input clock signal an output clock signal 
having a frequency twice that of the input clock signal, 
according to another embodiment of the invention. 
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circuit of Fig. 1, with delay element 102 being implemented 
using a DLL (including elements 402-407), and logical OR gate 
401 corresponding to logical OR gate 101. However, the 
circuit of Fig. 4 has the advantage of supporting a range of 
input clock frequencies, rather than being tailored to 
support a single clock frequency. 

[0042] The clock doubler of Fig. 4 includes logical OR 
gate 401, delay chains 402-403, clock multiplexers 404-405, 
phase detector 406, and state machine 407. Delay chains 402- 
403 and multiplexers 404-405 provide signals CLK180 and 
CLK360, respectively, delayed from signal CLKIN by one-half 
and one full clock cycle, respectively. (Note that as in the 
circuit of Fig. 1, the signal name CLK180 denotes a signal 
delayed by one-half clock period, i.e., 180 degrees, from 
input clock signal CLKIN.) Logical OR gate 401 is driven by 
input clock signal CLKIN and signal CLK180 from the DLL. 
[0043] Signal CLK360 is provided to phase detector 406 
along with input signal CLKIN, and phase detector 406 
provides control signals CTRL (e.g., signals ADD and 
SUBTRACT, not shown) indicating a phase relationship between 
signals CLKIN and CLK360. State machine 407 receives control 
signals CTRL and provides SELECT signals that control clock 
multiplexers 404 and 405 to select appropriate clock signals ■ 
CLK180 and CLK360. Thus, the DLL comprising elements 402-407 
ensures the correct phase relationship between each signal 
CLK180, CLK360 and input clock signal CLKIN, and the clock 
doubler circuit is accurate over a range of input clock 
frequencies. The output clock signal CLK2X has twice the 
duty cycle of input clock signal CLKIN. 

[0044] A significant disadvantage of the circuit of Fig. 4 
is that implementing DLLs typically requires a large amount 
of circuitry. 

[0045] The circuit of Fig. 4 can also be modified by 
adding a one- shot to the input clock path (see one-shot 203 
of Fig. 2) . The resulting clock doubler circuit supports 
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input clock signals having duty cycles greater than 50 
percent . 

[0046] Fig. 5 illustrates another known clock doubler 
circuit that includes a DLL. The clock doubler of Fig. 5 
supports a range of input clock frequencies, as in the clock 
doubler circuit of Fig. 4, but provides an output clock 
signal CLK2X having a 50 percent duty cycle. 
[0047] The clock doubler of Fig. 5 includes clock 
generator 511, delay chains 501-504, clock multiplexers 505- 
508, phase detector 509, and state machine 510. Delay chains 
501-504 and multiplexers 505-508 provide signals CLK90, 
CLK180, CLK270, and CLK360, respectively, delayed from signal 
CLKIN by one-quarter, one-half, three-quarters, and one full 
clock cycle, respectively. Clock generator 511 is driven by 
signals CLKIN, CLK90, CLK180, and CLK270, and provides output 
clock signal CLK2X. 

[0048] Signal CLK360 is provided to phase detector 509 
along with input signal CLKIN, and phase detector 509 
provides control signals CTRL (e.g., signals ADD and 
SUBTRACT, not shown) indicating a phase relationship between 
signals CLKIN and CLK360. State machine 510 receives control 
signals CTRL and provides SELECT signals that control clock 
multiplexers 505-508 to select appropriate clock signals 
CLK90, CLK180, CLK270, and CLK360. Thus, the DLL comprising 
elements 501-511 ensures the correct phase relationship 
between each signal CLK90, CLK180, CLK270, CLK360 and input 
clock signal CLKIN, and the clock doubler circuit is accurate 
over a range of input clock frequencies. Clock generator 511 
uses the signals CLKIN, CLK90, CLK180, and CLK270, which 
accurately reflect the starting point, one-quarter, one-half, 
and three-quarter points of the input clock cycle, to 
generate successive edges of output clock signal CLK2X. 
Thus, signal CLK2X has a 50 percent duty cycle. 
[0049] As in the circuit of Fig. 4, implementing the 
circuit of Fig. 5 requires a large amount of circuitry. The 
circuit can be reduced in size by using a PLL. However, PLLs 

10 



X-1464 US 



PATENT 



are very process -dependent, as described in the background 
section above, and digital solutions are often preferred. 
[0050] Fig. 6 illustrates a circuit providing the same 
advantages (50 percent duty cycle, wide range of input 
frequencies), but requiring less circuitry than the circuit 
of Fig. 5. The circuit of Fig. 6 is small enough, for 
example, to be a practical addition to user circuits 
implemented in programmable logic devices (PLDs) such as 
field programmable gate arrays (FPGAs ) . 

[0051] Fig. 6 is a schematic diagram of a clock doubler 
circuit according to one embodiment of the invention that 
includes four counters 601-604, a register 605, a reset 
circuit (flip-flop 606 and inverter 609), and an output clock 
generator (elements 607-608 and 610-611) . The circuit of 
Fig. 6 operates as shown in Fig. 7. Thus, the combination of 
Figs. 6 and 7 should be consulted in conjunction with the 
following explanation of the circuit of Fig. 6. 
[0052] Counter 1 (601) uses a relatively faster clock 
signal (e.g., generated by an oscillator circuit 626) to 
count a number of counts P in one period of input clock 
signal CLKIN. The number of counts P is stored in register 
605. When signal CLKIN goes high at time TO, the power high 
VDD value is clocked into flip-flop 607, driving signal CLK0 
high and resulting in a high value on signal CLK2X. The 
number of counts P is recounted, in the pictured embodiment, 
during every fifth input clock cycle. 
[0053] Counters 2, 3, and 4 (602, 603, and 604, 
respectively) are clocked by similar faster clock signals 
(e.g., generated by oscillator circuits having the same 
design and configuration as oscillator circuit 626) . Counter 
2 (602) starts counting when input clock signal CLKIN 
(ClkStart) goes high, and compares the count value with one- 
fourth of the value stored in register 605 (i.e., P/4) . Note 
that counter 2 does not use the two least significant bits 
from register 605, thus dividing the value in register 605 by 
four to provide the counter stop value Qstop[N:0]. When the 
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value in counter 2 reaches P/4 (at time Tl of Fig. 7), 
counter 2 (602) provides a high output pulse on signal RSTO. 
The high output pulse resets flip-flop 607, driving signal 
CLKO low at time Tl, as shown in Fig. 7. The high output 
pulse also resets counter 2. Because signal CLK180 is also 
low, NOR gate 611 provides a high value to inverter 610, 
which drives output clock signal CLK2X low at time Tl. 
[0054] Counter 3 (603) starts counting when input clock 
signal CLKIN (ClkStart) goes high, and compares the count 
value with one-half of the value stored in register 605 
(i.e., P/2) . Note that counter 3 does not use the least 
significant bit from register 605, thus dividing the value in 
register 605 by two to provide the counter stop value 
Qstop[N:0]. When the value in counter 3 reaches P/2 (at time 
T2 of Fig. 7), counter 3 (603) provides a high output pulse 
on signal SET180. The high output pulse clocks the power 
high VDD value into flip-flop 608, driving signal CLK180 high 
at time T2, as shown in Fig. 7. The high output pulse also 
resets counter 3. In response, NOR gate 611 provides a low 
value to inverter 610, which drives output clock signal CLK2X 
high at time T2 . 

[0055] Counter 4 (604) starts counting when signal SET180 
(ClkStart) goes high, and compares the count value with one- 
fourth of the value stored in register 605 (i.e., P/4). Note 
that counter 4 does not use the two least significant bits 
from register 605, thus dividing the value in register 605 by 
four to provide the counter stop value Qstop[N:0]. When the 
value in counter 4 reaches P/4 (at time T3 of Fig. 7), 
counter 4 (604) provides a high output pulse on signal 
RST180. The high output pulse resets flip-flop 608, driving 
signal CLK180 low at time T3, as shown in Fig. 7. The high 
output pulse also resets counter 4. Because signal CLKO is 
also low, NOR gate 611 provides a high value to inverter 610, 
which drives output clock signal CLK2X low at time T3 . 
[0056] In the pictured embodiment, the reset signal for 
each of counters 1-4 (601-604) and register 605 is signal 
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RST2, which is provided by flip-flop 606. Whenever a global 
reset signal RST is high (active), flip-flop 606 ensures that 
signal RST2 is also high, resetting all counters and register 
605. Whenever the global reset signal RST is low (inactive), 
flip-flop 606 clocks in the low value and drives signal RST2 
low on the next falling edge of signal CLKIN. 
[0057] in the pictured embodiment, counter 1 (601) is 
designed to recount the length of the input clock pulse 
(i.e., to generate a new value of P) every fifth clock cycle. 
In other embodiments, the periodicity of the count has other 
values, e.g., the desired periodicity can be selected based 
on the stability of the input clock frequency. In other 
embodiments, other implementations of counter circuit 601 are 
used. Any appropriate embodiment can be used. 
[0058] Counter circuit 601 has as inputs input clock 
signal CLKIN and reset signal RST2 . Counter circuit 601 
provides a clock update signal CLKJJPDT and a counter output 
bus QC[N:0]. In the pictured embodiment, counter circuit 601 
includes a counter 627, which counts a number of counts in 
one period of the input clock signal CLKIN. 
[0059] In the pictured embodiment, counter circuit 601 
includes reset flip-flops 621-624, set flip-flop 625, 
oscillator circuit 626, and counter 627. Flip-flops 621-625 
are coupled in series, and serve to provide three non- 
overlapping clock pulses in the following repeating sequence: 
RST_QP, CLK_QP, and CLKJJPDT. Each of these signals is high 
for only one clock cycle. 

[0060] Initially, signal RST_QP is high, because flip-flop 

625 is a set flip-flop, and counter 627 is reset. The first 
rising edge of signal CLKIN brings signal RST_QP low. On the 
second rising edge of signal CLKIN, signal CLK_QP provides a 
high value on oscillator enable signal EN to oscillator 
circuit 62 6. Thus, oscillator enable signal EN is high for 
one out of every five input clock cycles. Oscillator circuit 

626 generates a relatively fast oscillator output signal OUT . 
(i.e., faster than input clock signal CLKIN) whenever signal 
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[0063] Any known oscillator circuit can be used to 
implement oscillator circuit 802 of Fig. 8 and oscillator 
circuit 626 of Fig. 6. Preferably, the same implementation 
is used for all four oscillator circuits in the clock 
doubler, as this approach creates a high correlation between 
the four oscillators irregardless of external factors such as 
processing and temperature variations. For example, the well 
known ring oscillator design (e.g., a loop including an odd 
number of logic gates, e.g., two inverters and a NAND gate 
driven by the enable signal) can be used. This embodiment is 
particularly useful when the clock doubler circuit is 
implemented in a PLD, because the oscillator can be 
implemented using the programmable logic blocks of the PLD. 
In some embodiments, external oscillators are used. 
[0064] Any known counter or counters can be used to 
implement counter 803 of Fig. 8 and/or counter 627 of Fig. 6. 
For example, the well known ripple counters can be used. In 
some embodiments, double-edge flip-flops are used to double 
the count stored in the counter. In some embodiments, a 
first subset of the counters use double-edge flip-flops with 
a first oscillator frequency, while a second subset of the 
counters use single-edge flip-flops with a second oscillator 
frequency twice that of the first oscillator frequency. 
[0065] Any known comparator can be used to implement 
comparator 804 of Fig. 8. For example, the well known 
exclusive-NOR (XNOR) implementation can be used, wherein each 
pair of bits is provided to an XNOR gate, the XNOR gates are 
combined using NAND gates, and the NAND gates each drive a 
NOR gate providing the Pulse output signal in Fig. 8. 
[0066] Fig. 9 is a schematic diagram of a clock doubler 
circuit according to another embodiment of the invention that 
provides 25 percent DCC. The embodiment of Fig. 9 is similar 
to that of Fig. 6, but counters 2-4 (counters 602-604) are 
provided with different stop values, altering the positions 
of the output clock edges. Note that the elements of Fig. 9 
are similar to those of Fig. 6, and are similarly 
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interconnected, except as is now described. Fig. 10 is a 
timing diagram for the clock doubler circuit of Fig. 9. 
[0067] Counter 1 (601) uses a relatively faster clock 
signal (e.g., generated by oscillator circuit 626) to count a 
number of counts P in one period of input clock signal CLKIN. 
The number of counts P is stored in register 605. When 
signal CLKIN goes high at time TO, the power high VDD value 
is clocked into flip-flop 607, driving signal CLK0 high and 
resulting in a high value on signal CLK2X. The number of 
counts P is recounted, in the pictured embodiment, during 
every fifth clock cycle. 

[0068] Counters 2, 3, and 4 (602-604) are clocked by 
similar faster clock signals (e.g., generated by oscillator 
circuits having the same design and configuration as 
oscillator circuit 626). Counter 2 (602) starts counting 
when input clock signal CLKIN (ClkStart) goes high, and 
compares the count value with one-eighth of the value stored . 
in register 605 (i.e., P/8) . Note that counter 2 does not 
use the three least significant bits from register 605, thus 
dividing the value in register 605 by eight to provide the 
counter stop value Qstop[N:0]. When the value in counter 2 
reaches P/8 (at time Tl ' of Fig. 10), counter 2 (602) 
provides a high output pulse on signal RST0. The high output 
pulse resets flip-flop 607, driving signal CLK0 low at time 
Tl ' , as shown in Fig. 10. The high output pulse also resets 
counter 2. Because signal CLK180 is also low, NOR gate 611 
provides a high value to inverter 610, which drives output 
clock signal CLK2X low at time Tl ' . 

[0069] Counter 3 (603) functions in the same fashion as in 
the embodiment of Fig. 6, driving output clock signal CLK2X 
high at time T2 . 

[0070] Counter 4 (604) starts counting when signal SET180 : 
(ClkStart) goes high, and compares the count value with one- 
eighth of the value stored in register 605 (i.e., P/8). Note 
that counter 4 does not use the three least significant bits 
from register 605, thus dividing the value in register 605 by 
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eight to provide the counter stop value Qstop[N:0]. When the 
value in the counter reaches P/8 (at time T3 1 of Fig. 10), 
counter 4 (604) provides a high output pulse on signal 
RST180. The high output pulse resets flip-flop 608, driving 
signal CLK180 low at time T3 ' , as shown in Fig. 7. The high 
output pulse also resets counter 4. Because signal CLKO is 
also low, NOR gate 611 provides a high value to inverter 610, 
which drives output clock signal CLK2X low at time T3 * . 
[0071] The embodiment of Figs. 9 and 10 demonstrates that 
the clock edges of the output clock signal CLK2X can be moved 
by altering the stop values (Qstop[N:0]) for counters 602- 
604. In the embodiments of Figs. 6-10, the stop values are 
obtained from the registered value by shifting the bits to 
divide by values of two, four, or eight, for example. Figs. 
11-12 illustrate an embodiment in which the stop values are 
altered in another fashion- -by adding or subtracting a value 
from the stop values for the counters, thereby providing a 
predetermined offset value for alternating clock cycles. 
[0072] The clock doubler circuit of Fig. 11 provides 25 
percent DCC and a predetermined offset. The circuit includes 
four counters 601-604 (which can be similar, for example, to 
counters 601-604 of Figs. 6 and 9), a divide-by-eight 
register 1102, a divide-by-two register 1103, a reset circuit 
(flip-flop 606 and inverter 609, similar to the elements of 
Figs. 6 and 9), and an output clock generator (elements 607- 
608 and 610-611, also similar to the elements of Figs. 6 and ■ 
9). The circuit of Fig. 11 operates as shown in Fig. 12. 
Thus, the combination of Figs. 11 and 12 should be consulted 
in conjunction with the following explanation of the circuit 
of Fig. 11. Functionality similar to that of previous 
figures is not further described. 

[0073] Counter 1 (601) functions in the same fashion as in 
Figs. 6 and 9. Thus, the number of counts P is provided on 
output terminals QC[N:0]. The number of counts P can be 
recounted, for example, every fifth clock cycle. 
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[0074] The number of counts P is provided to divide-by- 
eight register 1102, where the value is divided by eight and 
registered. For example, the division can be performed by 
simply shifting the number of counts by three bits towards 
the least significant bit (LSB) , as in the embodiments of 
Figs. 6 and 9. In some embodiments, divide-by-eight register 
1102 is implemented as shown in Fig. 13. From divide-by- 
eight register 1102, the divided value is provided to the 
Qstop terminals of counters 602 and 604 via signals 
Q_45[N:0] . 

[0075] The number of counts P is also provided to divide- 
by- two register 1103, but is first altered by adding or 
subtracting a value from the number of counts using 
adder/subtractor 1104. (In some embodiments, not shown, the 
number of counts is first divided and then offset by a 
predetermined value, rather than performing the offset prior 
to the division as in the pictured embodiment.) The offset 
divided value Qof f set [N: 0] is divided by two (e.g., by 
shifting by one bit towards the LSB) and stored. One 
embodiment of divide-by- two register 1103 is shown in Fig. 
14. The divided and offset value is provided to counter 3 
(603) as the stop value Qstop[N:0] via signals Q_180[N:0]. 
Adder/subtractors are well known in the relevant arts, and 
any suitable implementation can be used. 

[0076] As in previously described embodiments, counters 2, 
3, and 4 (602, 603, and 604) are clocked by similar faster 
clock signals (e.g., generated by oscillator circuits having 
the same design and configuration as oscillator circuit 626) . 
Counter 2 (602) starts counting when input clock signal CLKIN 
(ClkStart) goes high, and compares the count value with the 
value stored in divide-by-eight register 1102 (i.e., one- 
eighth of the value stored in register 605, or P/8) . When 
the value in the counter reaches P/8 (at time Tl ' of Fig. 
12), counter 2 (602) provides a high output pulse on signal 
RST0. The high output pulse resets flip-flop 607, driving 
signal CLK0 low at time Tl ' , as shown in Fig. 12. The high 
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embodiments, the number of bits varies. For example, in the 
embodiment of Figs. 11-14, if counter 1 provides an 8-bit 
value, counters 2 and 4 can be only 5 bits wide, while 
counter 3 is 7 bits wide. However, this type of 
simplification will be clear to those of skill in the 
relevant arts. Therefore, the simpler approach of consistent 
bit width is used in the diagrams herein, for clarity. 
[0081] The register of Fig. 13 includes five reset flip- 
flops 1301-1305 coupled to receive signals Q[3:7], 
respectively, and to provide signals Q_45[0:4], respectively. 
The shift by three bits towards the LSB performs the divide- 
by-eight function. The three upper bits Q_45[5:7] are in 
this embodiment provided by a ground signal GND through 
inverters 1311-1312, 1313-1314, and 1315-1316, respectively. 
In other embodiments, inverters 1311-1316 are omitted. In 
yet other embodiments, the output bus provided by register 
1102 is narrower than the output bus from counter 601 (i.e., 
the upper bits of bus Q_45 are omitted) , and one or both of 
counters 602 and 604 include fewer bits than counter 601. 
[0082] Fig. 14 is a schematic diagram of divide-by- two 
register 1103 that can optionally be used in the embodiment 
of Fig. 11. The register of Fig. 14 includes seven reset 
flip-flops 1401-1407 coupled to receive signals Q[l:7], 
respectively, and to provide signals Q_180[0:6], 
respectively. The shift by one bit towards the LSB performs 
the divide-by-two function. The upper bit Q_180[7] is in 
this embodiment provided by a ground signal GND through 
inverters 1411-1412, respectively. In other embodiments, 
inverters 1411-1412 are omitted. In yet other embodiments, 
the output bus provided by register 1103 is narrower than the 
output bus from counter 601 (i.e., the most significant bit 
of bus Q_180 is omitted) , and counter 603 includes one fewer 
bit than counter 601. 

[0083] Fig. 15 is a schematic diagram of a clock doubler 
circuit according to another embodiment of the invention. 
The clock doubler circuit of Fig. 15 does not provide DCC. 
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Functionality the same as that of previous embodiments is not 
further described. 

[0084] The circuit of Fig. 15 includes three counters 601 
and 603-604 (which can be similar, for example, to counters 
601 and 603-604 of Figs. 6, 9, and 11), a divide-by-two 
register 1103 (which can be similar, for example, to register 
1103 of Fig. 11), a reset circuit (flip-flop 606 and inverter 
609, similar to the elements of Figs. 6, 9, and 11), an 
output clock generator (elements 608 and 610-611), and 
inverter 1501. The circuit of Fig. 15 does not include an 
equivalent counter to counter 2 of Figs. 6, 9, and 11. 
[0085] Counter 1 (601) functions in the same fashion as in 
Figs. 6, 9, and 11. Thus, the number of counts P is provided 
on output terminals QC[N:0] . The number of counts P can be 
recounted, for example, every fifth clock cycle. The number 
of counts P is provided to divide-by- two register 1103, where 
the value is divided by two (e.g., by shifting by one bit 
towards the LSB) and stored. 

[0086] When signal CLKIN pulses high, the high pulse is 
echoed on output terminal CLK2X (via NOR gate 611 and 
inverter 610) . To provide the clock doubler function, a 
second clock pulse must be generated halfway through the 
input clock cycle. 

[0087] Counter 3 (603) starts counting when input clock 
signal CLKIN (ClkStart) goes high, and compares the count 
value with the value stored in divide-by-two register 1103. 
Thus, the count value is compared to one-half of the count 
value P (i.e., P/2). when the value in counter 3 reaches 
this stop value, counter 3 (603) provides a high output pulse 
on signal SET180. The high output pulse clocks the power 
high VDD value into flip-flop 608, driving signal CLK180 
high. The high output pulse also resets counter 3. In 
response, NOR gate 611 provides a low value to inverter 610, 
which drives output clock signal CLK2X high. 
[0088] Counter 4 (604) starts counting when input clock 
signal CLKIN goes low (signal CLKIN inverted by inverter 1501 
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provides signal ClkStart) , and compares the count value with 
the value stored in divide -by- two register 1103. Thus, the 
count value is compared to one-half of the count value P 
(i.e., P/2) . When the value in counter 4 reaches this stop 
value, counter 4 (604) provides a high output pulse on signal 
RST180. The high output pulse resets flip-flop 608, driving 
signal CLK180 low. The high output pulse also resets counter 
4. Because signal CLKO is also low, NOR gate 611 provides a 
high value to inverter 610, which drives output clock signal 
CLK2X low. 

[0089] Thus, each of counters 3 and 4 (603 and 604) 
provides a clock edge having the same polarity as signal 
CLKIN, but delayed from signal CLKIN by one-half a CLKIN 
clock period. Thus, the clock doubler of Fig. 15 does not 
provide DCC. 

[0090] Note that in the pictured embodiment, when signal 
RST is high (active) , signal RST2 is high, signal RST180 is 
high (because the two values being compared are both low, see 
Fig. 8), and signal CLK180 is low. Thus, output signal CLK2X 
is the same as input signal CLKIN. 

[0091] Fig. 16 shows a variation of the embodiment of Fig. 
15 in which the output clock signal CLK2X is always low when 
signal RST is high. In the embodiment of Fig. 16, inverter 
610 of Fig. 15 is replaced by a NOR gate 1610, driven by NOR 
gate 611 and by signal RST2 . Thus, when signal RST goes 
high, signal RST2 goes high, and NOR gate 1610 drives signal 
CLK2X low. 

[0092] Fig. 17 is a schematic diagram of a clock doubler 
circuit according to an embodiment of the invention that 
optionally provides or does not provide DCC. The circuit of 
Fig. 17 is similar to the circuit of Fig. 9, with 
modifications that permit the optional selection of no DCC, 
as in Fig. 15. Only the differences from Fig. 9 are 
described. 

[0093] In addition to the elements shown in Fig. 9, the 
circuit of Fig. 17 includes three multiplexers 1702-1704 and 
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NAND gate 1705. Multiplexer 1702 is controlled by DCC enable 
signal DCC_EN to pass either signal CLKO as in Fig. 9 (when 
signal DCC_EN is high) or signal CLKIN as in Fig. 15 (signal 
DCC_EN is low) . Multiplexer 1703 is controlled by DCC enable 
signal DCC_EN to pass either signals GND, GND, GND, QP[N:3] 
as in Fig. 9 (when signal DCC_EN is high) or signals GND, 
QP[N:1], which are the equivalent signals to signals 
Q_180[N:0] in Fig. 15 (signal DCC_EN is low). Multiplexer 
1704 is controlled by DCC enable signal DCC_EN to pass either 
signal SET180 as in Fig. 9 (when signal DCC_EN is high) or 
the inverse of signal CLKIN as in Fig. 15 (signal DCC_EN is 
low) . 

[0094] NAND gate 1705 is driven by signal DCC_EN and by 
the inverse of signal RST2 . Thus, NAND gate 1705 controls 
the reset of counter 2 (602) by passing signal RST2 only when 
signal DCC_EN is high, i.e., when the DCC function is 
enabled. When signal DCC_EN is low (i.e., the DCC function 
is disabled), counter 2 (602) is always reset. 
[0095] Fig. 18 illustrates the steps of a novel method of ' 
providing from an input clock signal an output clock signal 
having a frequency twice that of the input clock signal, 
according to another embodiment of the invention. The steps 
of Fig. 18 can be performed, for example, using any of the 
circuits illustrated in Figs. 6-17. In some embodiments, the 
steps of Fig. 18 are performed by a circuit implemented in a 
programmable logic device (PLD) , for example in a field 
programmable gate array (FPGA) . 

[0096] In step 1801, a first number of counts between 
successive first edges of an input clock signal is counted. 
For example, in the embodiment of Fig. 15, counter 1 (601) 
counts a number P of oscillator clock cycles within a single 
period of input clock signal CLKIN . In some embodiments, the 
first edges are rising edges. 

[0097] in step 1802, the first number is divided to 
provide a divided number. In some embodiments, the number is 
stored, then is divided as it is passed to another circuit 
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(e.g., as in the embodiments of Figs. 6 and 9). In other 
embodiments, the number is divided prior to being stored in a 
register, as in the embodiments of Figs. 11, 15, and 16. In 
some embodiments, the number is divided by a factor of two. 
In other embodiments, divisors other than two are used. 
[0098] In step 1803, a second number of counts following 
each first edge of the input clock are counted, and the 
second number is compared with the divided number. 
[0099] In step 1804, a first pulse is provided on an 
output clock signal in response to each first edge of the 
input clock signal. 

[00100] In step 1805, a second pulse is provided on the 
output clock signal based on the results of comparing the 
second number with the divided number. In some embodiments, 
the second pulse is provided whenever the second number is 
the same as the divided number. In some embodiments, the 
second pulse is provided whenever the second number is the 
same as the divided number plus an offset value. In some 
embodiments, the second pulse is provided whenever the second 
number is the same as the divided number minus an offset 
value . 

[00101] In some embodiments, the first number of counts is 
repeated every M periods of the input clock signal, where M 
is an integer. In some embodiments, M is five. 
[00102] In some embodiments, the output clock signal has a 
predefined duty cycle independent of a duty cycle of the 
input clock signal. For example, the duty cycle of the 
output clock signal can be 50 percent, 2 5 percent, or some 
other desired value. 

[00103] Those having skill in the relevant arts of the 
invention will now perceive various modifications and 
additions that can be made as a result of the disclosure 
herein. For example, the above text describes the circuits 
and methods of the invention in the context of ICs such as 
programmable logic devices (PLDs) . However, the circuits of 
the invention can also be implemented in other electronic 
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